<template>
  <XtxDialog :title="`${formData.id?'修改':'添加'}收货地址`" v-model:visible="dialogVisible">
    <div class="address-edit">
        <div class="xtx-form">
      <div class="xtx-form-item">
        <div class="label">收货人：</div>
        <div class="field">
          <input v-model="formData.receiver" class="input" placeholder="请输入收货人" />
        </div>
      </div>
      <div class="xtx-form-item">
        <div class="label">手机号：</div>
        <div class="field">
          <input v-model="formData.contact" class="input" placeholder="请输入手机号" />
        </div>
      </div>
      <div class="xtx-form-item">
        <div class="label">地区：</div>
        <div class="field">
          <XtxCity @change="changeCity" :fullLocation="formData.fullLocation" placeholder="请选择所在地区"/>
        </div>
      </div>
      <div class="xtx-form-item">
        <div class="label">详细地址：</div>
        <div class="field">
          <input v-model="formData.address" class="input" placeholder="请输入详细地址" />
        </div>
      </div>
      <div class="xtx-form-item">
        <div class="label">邮政编码：</div>
        <div class="field">
          <input v-model="formData.postalCode" class="input" placeholder="请输入邮政编码" />
        </div>
      </div>
      <div class="xtx-form-item">
        <div class="label">地址标签：</div>
        <div class="field">
          <input v-model="formData.addressTags" class="input" placeholder="请输入地址标签，逗号分隔" />
        </div>
      </div>
    </div>
    </div>
    <template v-slot:footer>
      <XtxButton @click="addAddressCom=false" type="gray" style="margin-right:20px">取消</XtxButton>
      <XtxButton @click="confirmFn" type="primary">确认</XtxButton>
    </template>
  </XtxDialog>
</template>
<script>
import { ref,reactive } from 'vue'
import {addAddress,editAddress} from '@/api/order'
import Message from '@/components/library/Message'
export default {
  name: 'AddressEdit',
  setup (props,{emit}) {
    const dialogVisible = ref(false)
    // 打开函数
    const open = (address) => {
      dialogVisible.value = true
      if(address.id){
        // 修改地址
         for(const key in address){
            formData[key]=address[key] 
        }
      }else{
        // 添加地址
        for(const key in formData){
            if(key==='isDefault'){
                formData[key]=1
            }
            else{
                formData[key]=''
            }
        }
      }
    }
    // 表单数据对象
    const formData = reactive({
      receiver: '',
      contact: '',
      provinceCode: '',
      cityCode: '',
      countyCode: '',
      address: '',
      postalCode: '',
      addressTags: '',
      isDefault: 1,
      fullLocation: ''
    })
    // 城市选择
    const changeCity=(data)=>{
        formData.provinceCode=data.provinceCode
        formData.cityCode=data.cityCode
        formData.countyCode=data.countyCode
        formData.fullLocation=data.fullLocation
    }

    // 确认按钮
    const confirmFn=()=>{
        // console.log('a',formData);
        // 表单校验
        // 提交
        if(formData.id){
            // 添加
            editAddress(formData).then(data=>{
                 Message({ text: '修改收货地址成功', type: 'success' })
                 dialogVisible.value = false
                 // 触发自定义事件
                 emit('onSuccess', formData)
           }).catch(e=>{})
        }
        else{
            // 修改
            addAddress(formData).then(data=>{
                Message({ text: '添加收货地址成功', type: 'success' })
                formData.id = data.result.id
                dialogVisible.value = false
                // 触发自定义事件
                emit('onSuccess', formData)
            }).catch(e=>{})
        }
    }

    return { dialogVisible, open,formData,confirmFn,changeCity }
  }
}
</script>
<style scoped lang="less">
.address-edit {
.xtx-dialog {
  :deep(.wrapper){
    width: 780px;
    .body {
      font-size: 14px;
    }
  }
}
.xtx-form {
  padding: 0;
  input {
    outline: none;
    &::placeholder {
      color: #ccc;
    }
  }
}
.xtx-city {
  width: 320px;
  :deep(.select) {
    height: 50px;
    line-height: 48px;
    display: flex;
    padding: 0 10px;
    justify-content: space-between;
    .placeholder {
      color: #ccc;
    }
    i {
      color: #ccc;
      font-size: 18px;
    }
    .value {
      font-size: 14px;
    }
  }
  :deep(.option) {
    top: 49px;
  }
}
}
</style>